

05/30/00  
16784 U.S. PTO

05-31-00

JC583 U.S. PTO  
09/580755  
05/30/00

**IN THE UNITED STATES PATENT AND TRADEMARK OFFICE**

In re Patent Application of: Hong Wang et al.  
Title: CONJUGATE FLOW PROCESSOR  
Attorney Docket No.: 884.225US1

**PATENT APPLICATION TRANSMITTAL**

**BOX PATENT APPLICATION**  
Assistant Commissioner for Patents  
Washington, D.C. 20231

We are transmitting herewith the following attached items and information (as indicated with an "X"):

Utility Patent Application under 37 CFR § 1.53(b) comprising:  
 Specification ( 28 pgs, including claims numbered 1 through 30 and a 1 page Abstract).  
 Formal Drawing(s) ( 4 sheets).  
 Signed Combined Declaration and Power of Attorney ( 16 pgs).  
 Check in the amount of \$1,026.00 to pay the filing fee.  
Assignment of the invention to Intel Corporation ( 8 pgs) and Recordation Form Cover Sheet.  
 Check in the amount of \$40.00 to pay the Assignment recording fee.  
 Return postcard.

The filing fee has been calculated below as follows:

|                                                                  | No. Filed    | No. Extra | Rate   | Fee               |
|------------------------------------------------------------------|--------------|-----------|--------|-------------------|
| TOTAL CLAIMS                                                     | 30 - 20 =    | 10        | x 18 = | <b>\$180.00</b>   |
| INDEPENDENT CLAIMS                                               | 5 - 3 =      | 2         | x 78 = | <b>\$156.00</b>   |
| <input type="checkbox"/> [ ] MULTIPLE DEPENDENT CLAIMS PRESENTED |              |           |        | <b>\$0.00</b>     |
| BASIC FEE                                                        |              |           |        | <b>\$690.00</b>   |
|                                                                  | <b>TOTAL</b> |           |        | <b>\$1,026.00</b> |

**Please charge any additional required fees or credit overpayment to Deposit Account No. 19-0743.**

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.  
P.O. Box 2938, Minneapolis, MN 55402 (612-373-6900)

By: Ann M. McCrackin  
Atty: Ann M. McCrackin  
Reg. No. 42,858

**Customer Number 21186**

"Express Mail" mailing label number: EL584209602US

Date of Deposit: May 30, 2000

I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Box Patent Application, Washington, D.C. 20231.

By: Shawn L. Hise

Signature: 

UNITED STATES PATENT APPLICATION

**CONJUGATE FLOW PROCESSOR**

**INVENTORS**

**Hong Wang**

**Ralph Kling**

**Yong-Fong Lee**

**David Berson**

**Michael Kozuch**

**Konrad Lai**

Schwegman, Lundberg, Woessner & Kluth, P.A.  
1600 TCF Tower  
121 South Eighth Street  
Minneapolis, MN 55402  
ATTORNEY DOCKET SLWK 884.225US1  
Client Reference P7907

## CONJUGATE FLOW PROCESSOR

### Field

5

The present invention relates generally to microprocessors, and more specifically to microprocessors that support dynamic optimization of software.

### Background of the Invention

10

Modern microprocessors and software compilers employ many techniques to help increase the speed with which software executes. Examples of techniques that are used to help speed up the execution speed of processors include speculative execution of code, reuse buffers that hold instances of previously executed software 15 for later reuse, and branch target buffers (BTB) that try to predict whether branches are taken.

Research is ongoing in areas of modeling processor performance. See Derek B. Noonburg & John P. Shen, "Theoretical Modeling of Superscalar Processor performance," MICRO-27, November 1994; and Derek B. Noonburg & John P. 20 Shen, "A Framework for Statistical Modeling of Superscalar Processor Performance," Proceedings of the Third International Symposium on High Performance Computer Architecture, February 1997.

Some modern processors employ dynamic optimization that attempt to more fully utilize the resources of the processor. Approaches include: control speculation 25 using predicate promotion; load speculation using advanced or speculative advanced load or prefetch load; and static hints for branch direction or cache placement for loads. Many of these approaches can result in "non-essential" code used for optimization being intermixed with "essential" application level software code.

The essential code is typically created by a compiler from the application 30 level software code. The essential code is what determines the logical correctness of the resulting program. The non-essential code is also typically created by a compiler,

but it differs from the essential code in that it is a result of optimizations and other compile-time operations, rather than the applications level software program.

Intermixing of non-essential code and essential code creates competition for processor resources between the two types of code. Although a net increase in 5 execution speed can result from the above techniques, if the competition for resources is fierce, the above techniques can slow down the execution of the application level software.

In addition to static intermixing of non-essential code with essential code, some known dynamic optimization techniques reorder machine instructions in an 10 attempt to more fully utilize processor resources. For example, dynamic optimizers can introduce non-essential prefetch instructions and intermix them with original essential code, and/or reorder the original essential code based on run-time dynamic profiling feedback. This can lead to problems, in part because reordering of machine instructions may draw out latent “bugs” in the software, thereby sacrificing the 15 logical correctness of the application level software code. One example of a latent bug is an uninitialized variable. The bug may not be detected in the original code because of a fortuitous register assignment, but when instructions are reordered, the bug may manifest itself.

For the reasons stated above, and for other reasons stated below which will 20 become apparent to those skilled in the art upon reading and understanding the present specification, there is a need in the art for an alternate method and apparatus for combining essential code and non-essential code.

#### **Brief Description of the Drawings**

25

Figure 1 shows a conjugate processor;

Figure 2 shows a conjugate mapping table;

Figure 3 is a diagram showing the generation of a runtime binary with h-flow; and

30 Figure 4 shows a processing system.

## **Description of Embodiments**

5        In the following detailed description of the embodiments, reference is made to the accompanying drawings that show, by way of illustration, specific embodiments in which the invention may be practiced. In the drawings, like numerals describe substantially similar components throughout the several views. These embodiments are described in sufficient detail to enable those skilled in the art 10 to practice the invention. Other embodiments may be utilized and structural, logical, and electrical changes may be made without departing from the scope of the present invention. Moreover, it is to be understood that the various embodiments of the invention, although different, are not necessarily mutually exclusive. For example, a particular feature, structure, or characteristic described in one embodiment may be 15 included within other embodiments. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims, along with the full scope of equivalents to which such claims are entitled.

20        The method and apparatus of the present invention provide a mechanism for executing essential code and non-essential code in separate pipelines. A first pipeline executes the essential code which determines the logical correctness of the application level software. A second pipeline executes the non-essential code. A conjugate mapping table maps triggers that include instruction attributes, data attributes, event attributes, and state attributes to portions of the non-essential code. 25        When a trigger is “satisfied,” the non-essential code mapped thereto is executed in the second pipeline. In some embodiments, the non-essential code provides hints to increase efficiency of the operation of the first pipeline. In other embodiments, the non-essential code virtualizes instructions or groups of instructions in the essential code.

In this description essential and non-essential code are defined with respect to a particular reference architecture. Essential code is that code which is both necessary and sufficient for correct execution of a program on the reference architecture. Non-essential code is code which is not necessary for correct execution, 5 but which may benefit the performance of the essential code on the reference architecture. In a pure implementation of the reference architecture, all essential code is executed on a visible main pipeline, while all non-essential code is executed on a second internal pipeline, which may be optionally omitted with no impact on correctness of the executed program. In some embodiments that deviate from the 10 reference architecture, the visible main pipeline does not execute all of the essential code. In these embodiments, some essential code is executed on a second internal pipeline along with any non-essential code.

A typical example occurs when a first reference architecture is implemented as described, including the optional internal pipeline. A subsequent reference 15 architecture is then defined with functionality which is a proper superset of the first reference architecture. Using the optional internal pipeline, through mechanisms to be described, the original implemented architecture is then able to support the enhanced functionality of the subsequent reference architecture. The portion of essential code that uses the added functionality of the second reference architecture 20 cannot be executed on the visible main pipeline of the implemented architecture, and so is executed with any nonessential code on the internal pipeline instead.

Figure 1 shows a conjugate processor according to an embodiment of the present invention. Conjugate processor 100 includes instruction set architecture (ISA) visible path 102, microarchitectural structures 112, conjugate mapping table 25 200, h-flow cache 122, h-flow pipeline 120, and dynamic code analysis block 124. “H-flow” is a term that describes a “hint calculus” instruction flow that is separate from the main instruction flow in main pipeline 106 within ISA visible path 102. “Hint calculus” is a term that describes the action of h-flow pipeline 120 as it generates “hints” and communicates them to microarchitectural states 112. Hint

calculus is, by definition, non-essential code. In other words, hint calculus does not affect the logical correctness of the application level software.

ISA visible path 102 includes main pipeline 106 and structures associated therewith. Structures within ISA visible path 102 are visible to the applications level 5 programmer, hence the term “ISA visible.” Icache 104 receives instructions on node 108, and provides instructions to main pipeline 106 on node 110. Main pipeline 106 includes pipeline stages such as decoding, executing, and committing. In general ISA visible path 102, and main pipeline 106 in particular, execute essential code.

Icache 104 and h-flow cache 122 are logically separate cache memories.

10 Each holds instructions from different instruction streams. Icache 104 holds essential instructions and h-flow cache 122 holds non-essential instructions. In some embodiments, the physical design of the cache combines Icache 104 and h-flow cache 122. In these embodiments, an instruction fetched into h-flow cache 122 is available in Icache 104 to be fetched by main pipeline 106. In some embodiments, 15 this feature is exploited for instruction prefetch purposes by using h-flow pipeline 120 to prefetch essential instructions that are expected to be executed by main pipeline 106.

Main pipeline 106 communicates with microarchitectural structures 112. Microarchitectural structures 112 include structures that store the microarchitectural 20 states of the processor. Examples include register banks, branch target buffers (BTBs), data cache, and reuse buffers. Main pipeline 106 can retrieve state information from microarchitectural structures 112, and can also modify state information held in microarchitectural structures 112.

The terms “architectural structures” and “architectural states” are used herein 25 to describe the processor at a level that is visible to a programmer. For example, structures included within ISA visible path such as an architectural register file in main pipeline 106 are architectural structures. In contrast, the terms “microarchitectural structures” and “microarchitectural states” are used herein to refer to low level logical structures within the processor that are not necessarily 30 visible to a programmer. For example, conjugate processor 100 includes

microarchitectural structures 112 that are not within ISA visible path 102, but that can influence architectural states of main pipeline 106 using communications on node 114. In some embodiments, the architecture is implemented using the microarchitecture, and the architectural states are a subset of the microarchitectural

5 states.

Conjugate mapping table 200 receives instructions on node 108 and state information on node 126. The state information on node 126 can be microarchitectural or architectural state information. In some embodiments, conjugate mapping table 200 includes triggers and targets. When triggers are

10 satisfied, then the target is communicated to h-flow cache 122, which in turn provides instructions from h-flow memory or cache structures that include h-flow code (not shown) to h-flow pipeline 120. Conjugate mapping table 200 is explained more fully with reference to Figure 2 below. H-flow cache 122 can include actual h-flow code sequences, sometimes referred to as “handlers,” or can include pointers to

15 the handlers. H-flow cache 122 can also include pointers to data that is used by h-flow code.

In the reference architecture, h-flow is a conjugate flow that represents the logical conjugate of the normal instruction flow of the processor. The normal flow of the processor executes instructions that provide the logical correctness of the

20 program. For example, instructions compiled from a user’s program are executed in main pipeline 106, and this execution modifies the architectural state of processor 100 in the manner intended by the user. This is the essential code, or the code that ensures the architectural state is modified in the manner intended by the user. The code is called “essential” because it is what determines the final architectural state of

25 the processor.

H-flow code, in contrast, is “non-essential” code. It is referred to as non-essential because in some embodiments, it does not directly affect architectural states of processor 100, even though it may affect microarchitectural states of the processor. H-flow encodes or computes hints that can potentially lead to improved

30 efficiency in computation of the essential code in main pipeline 106.

As shown in Figure 1, h-flow pipeline 120 communicates with microarchitectural structures 112 on node 116. H-flow pipeline 120 can retrieve architectural or microarchitectural states on node 116, and can also modify microarchitectural states held in microarchitectural structures 112. In some 5 embodiments, h-flow code executed in h-flow pipeline 120 can also directly affect architectural states of conjugate processor 100.

Instructions defined for execution by h-flow pipeline 120 include instructions to handle state transfer and resource mapping between states of main pipeline 106 and states of h-flow pipeline 120. Examples include instructions to download states 10 from the main pipeline's registers to the h-flow pipeline's registers, and instructions to upload states from the h-flow pipeline's register to the main pipeline's registers.

Conjugate flow processor 100 provides a general schema to express a flexible association of diverse hints with the essential portion of the code at various granularities of instructions. This is provided through conjugate mapping table 200, 15 which is described more fully with reference to Figure 2 below. Because the non-essential portion of the code is not intermixed with the essential portion, conjugate processor 100 can support dynamic computation of hint calculus for any aspect of the microarchitectural optimization without impacting the organization of the essential code.

20 Dynamic code analysis block 124 analyzes the execution of code in main pipeline 106 and generates h-flow code. The generated h-flow code, when executed, provides hints to ISA visible path 102 in an attempt to improve execution behavior. For example, if a branch is usually taken under certain conditions, dynamic code analysis block 124 can generate h-flow code to support speculative execution of the 25 taken branch under the conditions discovered.

In some embodiments, dynamic code analysis generates h-flow code and replaces default h-flow code that was created at compile time. For example, in the case of a web browser capable of accepting “plug-ins,” optimum h-flow code for a plug-in cannot be generated at compile time for the web browser. When a plug-in is 30 installed in the web browser, the dynamic code analysis can adaptively modify the h-

flow code utilized with the plug in. The h-flow code can be saved in a “.hint” section so that the next time the plug-in is executed, the h-flow code that is loaded is the h-flow code generated for the plug-in. The .hint section is a section of an executable file, much like a .text, .bss, or .data section, and can be saved with the .hint section 5 for the web browser, or can be saved separately and dynamically linked when the web browser uses the plug-in. These mechanisms are explained more fully with reference to Figure 3 below.

In some embodiments, dynamic code analysis block 124 creates directed acyclic graph (DAG) trace representations of code executed in main pipeline 106.

10 The use of DAG traces in creating h-flow code is analogous to the ordering logic in an instruction scheduler. The instruction scheduler produces a DAG trace that identifies branch instructions that are either mostly taken or not taken. Dynamic code analysis block 124 captures the instruction DAG trace so that the next time the instruction is encountered, the previously generated DAG trace can be used. This 15 can be beneficial when compared to instruction schedulers that regenerate the DAG trace every time a branch instruction is encountered. In traditional trace cache implementations, a trace represents a sequence of instructions executed in a particular program order, and does not include information describing inter-instruction data dependencies. In contrast, a DAG trace in a DAG trace cache of the 20 present invention represents a sequence of instructions that are data dependent in program order.

Dynamic analysis block 124 is also useful to alleviate problems associated with cache misses for load instructions. For a load instruction on the critical path of a program (meaning many future operations are data dependent on the load 25 instruction) that frequently incurs cache misses, a DAG trace can be created that speculatively computes the memory access address for this load instruction. By running this DAG trace ahead of the flow in the main pipeline, the h-flow early run-ahead computation becomes essentially an “early probe for cache access prefetch.” Long before the instruction that uses a load is executed, the load is initiated. The h- 30 flow code includes instructions to determine the load address, and the load can be

performed as a prefetch by the h-flow pipeline. The data is loaded into data cache, and then the main pipeline can later access the data without causing a cache miss.

It is not necessary for conjugate processor 100 to include dynamic code analysis block 124. Although dynamic code analysis block 124 provides a flexible 5 mechanism for adaptively generating h-flow code, it is not the only mechanism to generate h-flow code. H-flow code can be statically generated, or can be dynamically linked from other sources. This is explained more fully with reference to Figure 3 below.

Because conjugate processor 100 allows parallelism between the computation 10 of the essential code and the computation of non-essential hint calculus code, little resource competition exists between the two flows.

H-flow code has many uses. Examples include sandbox checking, security checking, and instruction set virtualization at varying levels of abstraction. The remainder of this description discusses embodiments of conjugate processors and 15 related mechanisms. Any of the embodiments described can be utilized for any purpose to which an h-flow code sequence can be put. For example, the discussion below with reference to Figure 2 describes various embodiments of triggers that can be used to trigger h-flow code sequences. Any of these triggers can be used to trigger h-flow code for any purpose. Also for example, if a particular embodiment is 20 described with reference to h-flow code that adds security, it may also be the case that an h-flow code sequence supporting aggressive speculation can be substituted therefor without departing from the scope of the present invention.

Figure 2 shows a conjugate mapping table. Conjugate mapping table 200 is a hardware table that implements conjugate mapping between triggers 212 and targets 25 214. Conjugate mapping table 200 includes records 210, or “entries,” that each map a trigger to a target. Triggers are conditions that can be satisfied, and targets are references to h-flow code sequences 220. When a trigger in a record is satisfied, h-flow code specified by the target is triggered. As a result, the h-flow code is executed in the h-flow pipeline.

Triggers included within conjugate mapping table 200 can include any information useful to trigger the execution of an h-flow code sequence. Examples include instruction triggers, data triggers, state triggers, and event triggers.

Instruction triggers can trigger an h-flow code sequence based on an instruction

5 attributes such as address, opcode, operand, and the like. Data triggers can include data attributes such as data operand values, data locations (including memory locations and register IDs), and the like. State triggers include architectural and microarchitectural state information such as the state of microarchitectural structures that influence speculative execution, code reuse, and the like. Event triggers can

10 include any event that occurs when software is executing. Examples of events include processor interrupts and exceptions.

Trigger 202 is shown as an exploded view of one of triggers 212 in conjugate mapping table 200. Trigger 202 is a “vector” trigger made up multiple “atomic” attributes 204, 206, and 208. In general, triggers 212 can include single atomic

15 attributes, or can include vector triggers. When a trigger is specified as a vector, as in the example of trigger 202, the trigger is satisfied when a boolean function of the atomic values is satisfied. For example, in an embodiment where atomic value 204 includes an instruction location, atomic value 206 includes an instruction opcode, and atomic value 208 includes an instruction operand, and the boolean function is

20 “and,” trigger 202 is satisfied when the specified opcode and operand are fetched from the specified location. Atomic triggers can be negated, and by listing several vector triggers with the same target, a nearly arbitrary sum-of-product expression can be generated. For example, two vector triggers with the same target can be used to generate the logical function: “trigger h-flow A execution if (1) the instruction

25 pointer is X and register R is not zero, or (2) the instruction pointer is Y and the translation look-ahead buffer (TLB) is full. In some embodiments, Nth occurrence triggers are implemented. For example, an Nth occurrence trigger can implement the logical function: “trigger h-flow A execution if N BTB misses are observed.”

In some embodiments, targets within conjugate mapping table 200 represent

30 code and data. In other embodiments, targets within conjugate mapping table point

only to h-code sequences. The h-code sequences can have code sections and data sections such as “.text” section 222 and “.data” section 224 that are generated by a compiler. Within the data section, an h-flow sequence can save state information. For example, an h-flow sequence may be used to gather runtime profile information 5 later used to gather reuse instances for reusable blocks of essential code. This profile information can be saved in the data section.

### Instruction Triggers

Instruction triggers can specify conditions based on one or more instruction 10 attributes. These attributes include instruction locations (sometimes referred to as “instruction pointer values”), instruction opcodes, instruction operands, or the like. When one of these attributes is used alone, it is an atomic trigger. An atomic trigger is satisfied when the condition specified by the single attribute is satisfied. For example, if an atomic trigger specifies an instruction pointer value, the trigger is 15 satisfied when the instruction pointer value is encountered in the program, and the h-flow code specified in the target of the corresponding record is triggered as a result.

When an instruction opcode is mapped as an atomic trigger to an h-flow code sequence, the trigger is satisfied and the h-flow code sequence is executed when the opcode is encountered in the instruction stream. Likewise, when an instruction 20 operand is mapped as an atomic trigger to an h-flow code sequence, the trigger is satisfied when the operand is encountered in the instruction stream.

Instruction attributes can be utilized separately as atomic triggers, or they can be used in combination as vector triggers. For example, when an opcode and operand are utilized together to create a vector trigger, the trigger is satisfied when an 25 instruction is encountered having both the opcode and the operand. This allows more discrimination in the triggering of h-flow code sequences.

Example uses for triggers based on instruction attributes include speculative execution and computation reuse. For example, if a frequently encountered block of essential code can be reused, meaning for the same set of input values (livein states), 30 the code block produces the same set of output values (liveout states), the instruction

pointer marking the entrance to the reused block becomes a trigger entered in conjugate mapping table 200 and an h-flow code sequence implements the detection and verification of the reusability function in the h-flow pipeline to check whether there is a match of livein states. Likewise, if a particular branch within a program is 5 often taken, an instruction pointer value that precedes the branch can be used as a trigger to cause speculative execution of the code in the taken branch. The results of speculative execution in the h-flow pipeline can be used in multiple ways. For example, the states of the h-flow pipeline that result from speculative execution can be copied to the main pipeline, or the actions of the h-flow pipeline can cause the 10 instructions in the taken path to be fetched into instruction cache so that when the main pipeline takes the branch, the instructions are in instruction cache memory and can be fetched with low latency.

An example use of an instruction operand in a trigger includes the re-mapping of virtual register sets. In some embodiments, a memory address or register 15 ID can be specified as a trigger. When the location or register is accessed, the trigger is satisfied, and the corresponding h-flow code sequence is executed in the h-flow pipeline. If, in one generation of microprocessors, 128 registers exist, and in a later generation 256 exist, software compiled for the later generation may reference a register number higher than 128. When this code executes on the earlier generation 20 processor, conjugate mapping table 200 can have triggers that include a register address greater than 128. The trigger can cause h-flow code to perform a virtual mapping of registers such that software can run that attempts to access a greater number of registers than physically exist in a processor. In this manner, a bank of registers can be renamed or re-mapped using h-flow code sequences.

25 Like the alternative register mapping described above, when a memory location is used as an instruction operand atomic trigger in conjugate mapping table 200, alternative mappings for memory can be utilized. For example, a translation look ahead buffer (TLB) can be accessed with h-flow code. In this manner, an operating system can construct its own paging mechanism to manage a TLB

manipulated by h-flow code. This effectively allows an operating system to virtualize existing hardware normally built into the processor.

Another example use of instruction attributes as triggers involves error checking. For example, an h-flow code sequence that performs an error checking 5 routine can be triggered using an instruction operand as an atomic trigger. In this manner, certain registers, memory locations, or groups thereof, can be selectively subjected to error detection using h-flow.

Instruction attributes as atomic triggers allow interception of code in the main pipeline at the instruction level. The contents of the atomic trigger specify an 10 attribute of an instruction that is used for interception purposes. For example, when the atomic trigger is an instruction pointer, the instruction at that address triggers an h-flow sequence. Likewise, when the atomic trigger is an opcode, instructions represented by the opcode trigger an h-flow sequence. In the preceding paragraphs, atomic triggers have been described with reference to a few examples; however, any 15 type of instruction attribute can be utilized as an atomic trigger without departing from the scope of the present invention.

### Data Triggers

Data triggers can specify conditions based on one or more data attributes. 20 These attributes include data operand values, data locations (including memory locations and register IDs), and the like. When one of these attributes is used alone, it is an atomic trigger. For example, if a trigger specifies a data operand value, the trigger is satisfied when the data operand value is encountered in the program, and the h-flow code specified in the target of the corresponding record is triggered as a 25 result. Vector combinations of data attributes can also be used as triggers. For example, in an embodiment where a vector combination of data location and data operand value is used as a trigger, the trigger is satisfied when the data operand value and the data location are satisfied at once. This can occur when a “load” instruction loads the data operand value from the data location.

Typically, data operand values are available later in the pipeline process than instruction related values described above. For example, data operand values are usually available during execution, whereas instruction related information is usually available shortly after fetching.

5 One example use of a data operand as an atomic trigger is the register address of a register dedicated as the stack pointer. It may be beneficial to perform more checking when the data operand represents a stack pointer, than when the data operand represents any other register. When a stack pointer register is used as a data operand, an h-flow code sequence that checks the validity of the stack pointer can be  
10 triggered. This can add any level of checking using h-flow code. This is logically equivalent to built-in-self-test (BIST), but unlike traditional BIST that is hardwired during chip fabrication, h-flow enabled BIST allows more flexibility. H-flow enabled BIST provides the ability to circumvent known bad circuitry by emulating missing functionality or rerouting access around damaged resources. This is an  
15 example of microarchitectural level resource virtualization.

If the value in the stack pointer register is within a range expected to be a valid stack in a user program, more extensive checking may be employed. When the stack pointer represents the operating system kernel stack pointer, the context has switched from a user program to the kernel, and less checking may be needed. In  
20 general, any type of h-flow code sequence can be applied.

As previously described, any vector combination of atomic values can be utilized as a trigger in conjugate mapping table 200. Vector triggers can include instruction attributes, data attributes, or any other attributes in any combination. For example, when an instruction operand and a data operand value are combined as a  
25 vector trigger, an h-flow code sequence can be triggered when a particular data operand value is associated with a particular instruction operand. This allows an h-flow code sequence to be associated with particular runtime contexts, such as when the instruction operand is a stack pointer register, and the data operand value is a stack pointer value associated with a particular context.

H-flow code sequences can also be utilized to fetch into cache those instructions that are expected to be used by the main pipeline. When h-flow code prefetches instructions into cache, the fetching operation of the main pipeline can be much quicker. For example, when a user program calls a function in a dynamic link library (DLL), such as the “putc” function which prints a character in the “C” language, instructions associated with the function being called are resident in the DLL. An atomic or vector trigger can be built that represents an instruction prior to the DLL call, and can be used as a trigger for an h-flow code sequence that begins to fetch the instructions so that they are within cache when needed by the main pipeline.

10 A data location trigger can be utilized to trigger h-flow code sequences based on the location of a data value. For example, if a data value is resident within a protected area of memory, an h-flow code sequence can be triggered that verifies access privileges of the user executing the code in the main pipeline. This enables access sandboxing.

15 An h-flow code sequence can also be used for error detection and correction in specific areas of on-chip memory. For example, if one or more cache locations is known to be unreliable or defective, an atomic trigger or a vector trigger can be built that represents an access to the unreliable cache location and an h-flow code sequence that performs error detection and correction can be employed. In these 20 embodiments, the effective yield of the integrated circuit can be increased because the faulty cache locations can be made to function correctly. Effectively, the conjugate flow hardware and h-flow code become error-tolerating parity resources for the main pipeline.

25 State Triggers

State triggers can specify conditions based on one or more state attributes. These attributes include architectural and microarchitectural states. Examples include state information held in reuse buffers, branch target tables, and other microarchitectural structures that support speculation. State attributes can be 30 combined with instruction attributes and data attributes to create hybrid vector

triggers. When the hybrid vector trigger is satisfied, the corresponding h-flow code is triggered.

### Event Triggers

5 Triggers within conjugate mapping table 200 can also include event attributes. Examples of events are interrupts, exceptions, and the like. In some embodiments, events are fully specified using vector combinations of atomic instruction triggers and atomic data triggers. In this manner, h-flow code sequences can be utilized in place of interrupt routines and exception handlers, or can be  
10 utilized as epilogs and prologs of interrupt routines and exception handlers. Another example of an event usable as a trigger in conjugate mapping table 200 is a processor state register. In some embodiments, processor state registers include bits or values that represent interrupts and exceptions. When these bits or values are changed, interrupts or exceptions occur. When one of these interrupts or exceptions is to be  
15 used as an event trigger, the processor state register can be used as an event trigger.

Triggers can also be specified by otherwise unused portions of instruction opcodes or instructions words. For example, in a processor having a 64 bit instruction field with six unused bits, the six unused bits can be utilized as an conjugate mapping trigger. These otherwise unused bits can be used alone as an  
20 atomic trigger or can be used in combination with other atomic values to generate a vector trigger.

### Instruction Set Virtualization

“Instruction set virtualization” refers to an example use of conjugate  
25 processor 100 (Figure 1). This discussion of virtualization is set apart from other discussions of sample uses in part because code that executes on h-flow pipeline 120 in an embodiment supporting virtualization can be thought of as not strictly non-essential. In some embodiments, the implemented architecture is a subset of the reference architecture, and virtualization can support the emulation of the reference  
30 architecture on the implemented architecture.

In general, example uses of h-flow described thus far are hint calculus uses. When used for hint calculus, h-flow code includes purely non-essential code that only provides hints to affect execution of essential code on the main pipeline. If h-flow is purely non-essential, then even if the h-flow is wrong, the essential code will 5 still provide the correct result. For example, if non-essential h-flow code is designed to prefetch instructions on a predicted path, but the prediction is wrong, the h-flow will be wrong, but the correct essential instructions will eventually execute on the main pipeline, and the correct logical result will be obtained.

In some embodiments, the architecture of conjugate processor 100 (Figure 1) 10 is used to execute code on h-flow pipeline that is not strictly non-essential, but is nonetheless still invisible to the programmer. One such example use is virtualization of portions of a user program. Virtualization can be accomplished at varying levels of abstraction. For example, a single machine instruction can be virtualized using an opcode as a trigger. When the opcode is encountered, the trigger is satisfied, and an 15 h-flow code sequence is executed in the h-flow pipeline. The instruction is “virtualized” because the h-flow code sequence is meant to take its place. The results of the h-flow execution can replace the results of the instruction being virtualized.

The method and apparatus of the present invention provide a triggering 20 mechanism and closely coupled hidden microarchitecture pipeline to enable virtualization without affecting the main pipeline computation. In other words, instruction set virtualization is achieved without change to the original code in the main pipeline.

Instruction level virtualization can allow a non-native opcode to be 25 implemented on the processor, or an existing opcode can be mapped to a different function. For example, an opcode that is not defined in the instruction set of the processor can be implemented in h-flow code. The opcode is specified as an atomic trigger, and when the opcode is encountered in the main pipeline, the trigger is satisfied and instead of passing the opcode into the pipeline, the h-flow code 30 sequence executes on the h-flow pipeline. In some embodiments this can be useful

when software compiled for a later generation of processors is executed on an earlier generation that does not have the opcode defined. Forward compatibility can be provided for instructions implemented in the later generation of processors. In this manner, older processors can be dynamically upgraded such that they can execute 5 executable files that include processor instructions only defined in a newer generation of processor. This is an example of instruction semantic virtualization that implements forward compatibility.

Forward compatibility can also be implemented using event triggers. For example, if an unrecognized opcode is encountered, an exception will be generated. 10 The exception can be specified in conjugate mapping table as an event trigger, and an h-flow routine that executes the otherwise unknown opcode can be the target.

Instruction virtualization can also occur at a higher level. Conjugate mapping table 200 can re-map not just individual instructions, but also blocks of instructions into h-flow code. A group of instructions or an entire function or subroutine can be 15 replaced with h-flow code when an instruction pointer is used as an atomic trigger in conjugate mapping table 200. For example, an instruction pointer trigger can correspond to the first location in an integer divide routine. If, after the original integer divide routine is implemented, a faster algorithm becomes available in h-flow, the integer divide routine can be effectively replaced with h-flow using an 20 instruction pointer value as a trigger.

In many processors, inter-instruction communication is accomplished using architectural states. That is, one instruction modifies architectural states, and the next instruction begins operation with architectural states left by the last instruction. When h-flow code virtualizes an instruction, architectural states are modified, and 25 the next instruction uses the same inter-instruction mechanism for communications and the result is the same. Data states and control states can be updated. Data states include registers, and control states include next IP, BTB contents, and other microarchitectural states. The main pipeline then continues with the new IP.

Any suitable atomic value or vector can be used to trigger virtualization. For 30 example, an opcode can be an atomic trigger used to virtualize every occurrence of a

specific instruction, or an opcode can be combined with a location to virtualize a specific occurrence of an instruction.

Figure 3 is a diagram showing the generation of a runtime binary with h-flow. Figure 3 shows static binary 310 representing a user program being combined with 5 runtime library 320 at runtime to create runtime binary 330. Figure 3 is shown with one runtime library and one static binary; however, any number of runtime libraries can be included while still practicing the present invention.

As shown in Figure 3, static binary 310 with h-flow includes essential portion 312 and non-essential portion 314. Essential portion 312 of static binary 310 is 10 generated from source code 302 by compiler and linker 304. Compiler and linker 304 interoperate with profiler and profiled data 306 to generate non-essential portion 314 of static binary 310. Non-essential portion 314 of static binary 310 includes a .hint section and a .hint.2.text section. The .hint section includes h-flow code that provides hints for the execution of the .text section in essential portion 312 of static 15 binary 310. The .hint.2.text section includes conjugate mappings that trigger h-flow code sequences within the .hint section.

In general, any compiled object, such as static binary 310 or runtime library 320, can be generated having an essential portion and a non-essential portion, but this is not necessary. For example, a static binary may include a non-essential portion, 20 and a runtime library may only include an essential portion. Also, a runtime library may include a non-essential portion and not include an essential portion. In this case, the runtime library does not provide software to be linked with the static binary, but instead includes h-flow code to be linked with the non-essential portion of the static binary.

25 Non-essential portion 314 of static binary 310 is shown in Figure 3 as having been generated at compile time. This is in contrast to other methods previously described for generating h-flow. For example, dynamic code analysis block 124 (Figure 1) generates h-flow code and conjugate mappings adaptively. In some embodiments, statically created non-essential code sections, such as non essential 30 portion 314 of static binary 310, are “default” non-essential portions that are replaced

or augmented by adaptively created non-essential portions. For example, at runtime, dynamic code analysis block 124 (Figure 1) can modify or replace h-flow code and conjugate mappings. The modified (or new) conjugate mappings and h-flow code can be written out as new .hint.2.text and .hint sections respectively. In this manner, 5 statically created non-essential portions of programs can be replaced or dynamically modified over time.

The .hint and .hint.2.text sections are not necessary. For example, if static binary 310 is produced by a compiler without profile information, the .hint and .hint.2.text sections may not be created. In other embodiments, when profile 10 information is not available at compile time, default .hint and .hint.2.text sections are included within the static binary.

Runtime library 320 with h-flow includes essential portion 322 and non-essential portion 324. Essential portion 312 of static binary 310 and essential portion 322 of runtime binary 320 are combined at runtime by loader 340 to create essential 15 portion 332 of runtime binary 330. Likewise, non-essential portion 314 of static binary 310 and non-essential portion 324 of runtime library 320 are combined at runtime by hint loader 350 to create non-essential portion 334.

In some embodiments, runtime libraries do not exist, and runtime binary 330 does not include any information from runtime libraries. In other embodiments, 20 multiple runtime libraries exist and runtime binary 330 includes information from the static binary and the multiple runtime libraries.

At load time, loader 340 combines the essential sections from the different binaries and produces the essential portion of the runtime binary. The .text sections are combined such that programs within each can interoperate. The .data sections are 25 combined such that the data space for each is available at runtime. Also at load time, hint loader 350 combines the non-essential portions of the different binaries and produces the non-essential portion of the runtime binary. The .hint sections can be combined, or one can override the other. For example, the static .hint section can be a default hint section. In some embodiments, the operation of hint loader 350 is 30 hidden from the user.

Runtime binary 330 includes essential portion 332 and non-essential portion 334. Essential portion 332 includes a .text section and a .data section. Essential portion 332 can also include other sections such as a .bss section. Non-essential portion 334 includes a .hint section and a .hint.2.text section. The .hint section 5 includes h-flow code, and the .hint.2.text section includes conjugate mapping information. When the runtime binary with h-flow is executed, the .text section within essential portion 332 runs on a main pipeline that is visible to the instruction set architecture, such as main pipeline 106 (Figure 1). The .hint.2.text section within non-essential portion 334 is installed in a conjugate mapping table, such as conjugate 10 mapping table 200 (Figure 1), and the .hint section includes h-flow code sequences that run on an h-flow pipeline, such as h-flow pipeline 120 (Figure 1).

The non-essential code as generated by compiler and linker 304 and profiler and profiled data 306 can perform many different purposes as described above with reference to Figure 1. For example, the h-flow code can provide architecture specific 15 hints for the target platform. If a particular generation of processor is targeted, then the h-flow code can be generated targeted at that particular processor. Likewise, if a different generation of processor is targeted, then the h-flow code can be designed to generate hints appropriate for that processor.

Architecture specific h-flow code allows for common essential code to be 20 shared across several generations, and even separate architectures, of processors. For example, an essential portion of a static binary can be compiled once, and “optimizations” can be performed with h-flow at runtime.

The essential portion 312 of static binary 310 can be a “perpetual version” of an optimum essential binary assuming a near perfect microarchitecture (e.g. no 25 branch misprediction or cache miss). Non-essential portion 314 of static binary 310 can include microarchitecture specific non-essential code to implement the essential code on a specific microarchitecture. The combination of the “perpetual version” of the essential code and the microarchitectural specific non-essential code together can dynamically approximate the performance of the ideal microarchitecture.

Figure 4 shows a processing system. Processing system 400 includes processor 420 and memory 430. In some embodiments, processor 420 is a conjugate processor such as processor 100 (Figure 1). In some embodiments, processor 400 is a processor capable of compiling and loading software such as that shown in Figure 5 3. Processing system 400 can be a personal computer (PC), server, mainframe, handheld device, portable computer, set-top box, or any other system that includes software.

Memory 430 represents an article that includes a machine readable medium. For example, memory 430 represents any one or more of the following: a hard disk, a 10 floppy disk, random access memory (RAM), read only memory (ROM), flash memory, CDROM, or any other type of article that includes a medium readable by a machine. Memory 430 can store instructions for performing the execution of the various method embodiments of the present invention.

It is to be understood that the above description is intended to be illustrative, 15 and not restrictive. Many other embodiments will be apparent to those of skill in the art upon reading and understanding the above description. The scope of the invention should, therefore, be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.

Docket No. 884.225us1

What is claimed is:

- 1 1. A processor comprising:
  - 2 a first pipeline configured to execute essential code;
  - 3 a second pipeline configured to execute non-essential code; and
  - 4 a conjugate mapping table configured to specify non-essential code to be
  - 5 executed by the second pipeline.
  
- 1 2. The processor of claim 1 wherein the first pipeline is coupled to a first instruction cache configured to cache instructions that determine the logical correctness of a program.
  
- 1 3. The processor of claim 2 wherein the second pipeline is coupled to a second instruction cache configured to cache instructions that provide hints for the execution of the instructions that determine the logical correctness of the program.
  
- 1 4. The processor of claim 1 wherein the first pipeline is coupled to registers that store a microarchitectural state, and wherein the conjugate mapping table is responsive to the microarchitectural state.
  
- 1 5. The processor of claim 4 further comprising:
  - 2 a first instruction cache coupled to the first pipeline; and
  - 3 a second instruction cache coupled between the conjugate mapping table and
  - 4 the second pipeline.
  
- 1 6. The processor of claim 1 wherein the conjugate mapping table is responsive to a trigger, the trigger being mapped within the conjugate mapping table to the non-essential code.

0353012355 03530000

1 7. The processor of claim 1 wherein the conjugate mapping table comprises a  
2 plurality of records, each of the plurality of records being configured to map a trigger  
3 to a non-essential code sequence.

1 8. The processor of claim 7 wherein the trigger comprises an atomic value, such  
2 that the conjugate mapping table is configured to specify the non-essential code  
3 sequence when the atomic value is satisfied.

1 9. The processor of claim 7 wherein the trigger comprises a vector value, such  
2 that the conjugate mapping table is configured to specify the non-essential code  
3 sequence when the vector value is satisfied.

1 10. The processor of claim 1 further comprising a microarchitectural structure  
2 coupled between the first pipeline and the second pipeline.

1 11. The processor of claim 10 wherein the microarchitectural structure comprises  
2 a register bank.

1 12. A processor comprising:  
2 an instruction set architecture (ISA) visible path; and  
3 a conjugate pipeline coupled to the ISA visible path, the conjugate pipeline  
4 being configured to execute hint calculus code and to provide execution hints to the  
5 ISA visible path.

1 13. The processor of claim 12 wherein the processor can take on architectural  
2 states and microarchitectural states, the conjugate pipeline being configured to affect  
3 microarchitectural states.

1 14. The processor of claim 12 wherein the ISA visible path includes a pipeline  
2 configured to execute instructions from a user program.

1 15. The processor of claim 14 wherein the conjugate pipeline is configured to  
2 execute hint calculus code that virtualizes instructions from the user program.

1 16. A processor comprising:  
2 a conjugate mapping table coupled to a first pipeline, the conjugate mapping  
3 table including entries to map triggers from the first pipeline to hint calculus code  
4 sequences; and  
5 a second pipeline to execute the hint calculus code sequences.

1 17. The processor of claim 16 further comprising microarchitectural structures  
2 responsive to the second pipeline, the microarchitectural structures being configured  
3 to modify states of the first pipeline.

1 18. The processor of claim 17 wherein the microarchitectural structures comprise  
2 a branch target buffer.

1 19. The processor of claim 17 wherein the triggers comprise:  
2 instruction attributes;  
3 data attributes;  
4 state attributes; and  
5 event attributes.

1 20. The processor of claim 16 further comprising:  
2 an instruction cache coupled between the conjugate mapping table and the  
3 second pipeline, the instruction cache being configured to cache the hint calculus  
4 code sequences.

1 21. The processor of claim 16 wherein the processor is configured to execute  
2 essential code and non-essential code, and wherein the non-essential code comprises  
3 the hint calculus code sequences.

1 22. The processor of claim 16 wherein the second pipeline is configured to  
2 implement register file expansion for forward compatibility across different  
3 generations of processors.

1 23. The processor of claim 16 wherein the second pipeline is configured to  
2 implement built-in-self-test.

1 24. The processor of claim 16 wherein the second pipeline is configured to  
2 implement instruction set virtualization.

1 25. A computer-implemented method of creating a runtime binary comprising:  
2 combining an essential portion of a static binary with an essential portion of a  
3 runtime library to create an essential portion of the runtime binary; and  
4 creating a non-essential portion of the runtime binary using a non-essential  
5 portion of the static binary.

1 26. The computer-implemented method of claim 25 wherein creating a non-  
2 essential portion comprises:  
3 combining the non-essential portion of the static binary with a non-essential  
4 portion of the runtime library.

1 27. The computer-implemented method of claim 26 wherein combining the non-  
2 essential portion comprises:  
3 combining non-essential code from the static binary with non-essential code  
4 from the runtime library; and

5               combining conjugate mapping information from the static binary with  
6       conjugate mapping information from the runtime binary.

1   28.   An article having a machine readable medium with instructions for  
2       performing a method of creating a runtime binary disposed thereon, the method  
3       comprising:

4               combining an essential portion of a static binary with an essential portion of a  
5       runtime library to create an essential portion of the runtime binary; and  
6               creating a non-essential portion of the runtime binary using a non-essential  
7       portion of the static binary.

1   29.   The article of claim 28 wherein creating a non-essential portion comprises:  
2               combining the non-essential portion of the static binary with a non-essential  
3       portion of the runtime library.

1   30.   The article of claim 29 wherein combining the non-essential portion  
2       comprises:  
3               combining non-essential code from the static binary with non-essential code  
4       from the runtime library; and  
5               combining conjugate mapping information from the static binary with  
6       conjugate mapping information from the runtime binary.

## **Abstract of the Disclosure**

A conjugate processor includes an instruction set architecture (ISA) visible portion having a main pipeline, and an h-flow portion having an h-flow pipeline.

5 The binary executed on the conjugate processor includes an essential portion that is executed on the main pipeline and a non-essential portion that is executed on the h-flow pipeline. The non-essential portion includes hint calculus that is used to provide hints to the main pipeline. The conjugate processor also includes a conjugate mapping table that maps triggers to h-flow targets. Triggers can be

10 instruction attributes, data attributes, state attributes or event attributes. When a trigger is satisfied, the h-flow code specified by the target is executed in the h-flow pipeline.

"Express Mail" mailing label number: EL 584209602US

Date of Deposit: May 30, 2000

I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Washington, D.C. 20231

Printed Name: Shawn Hise

Signature: 





FIG. 2



FIG. 3



FIG. 4

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.

## United States Patent Application

### COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as stated below next to my name; that

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled: **CONJUGATE FLOW PROCESSOR**.

The specification of which is attached hereto.

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known to be material to patentability which became available between a filing date of a prior application and the national or PCT international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. § 1.63(e).

I hereby claim foreign priority benefits under 35 U.S.C. §119(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one country other than the United States of America, listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is claimed:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 119(e) of any United States provisional application(s) listed below:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. § 112, I acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became available between the filing date of the prior application and the national or PCT international filing date of this application:

**No such claim for priority is being made at this time.**

I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith:

|                        |                 |                             |                 |                       |                 |
|------------------------|-----------------|-----------------------------|-----------------|-----------------------|-----------------|
| Anglin, J. Michael     | Reg. No. 24,916 | Huebsch, Joseph C.          | Reg. No. 42,673 | Nama, Kash            | Reg. No. 44,255 |
| Bianchi, Timothy E.    | Reg. No. 39,610 | Jurkovich, Patti J.         | Reg. No. 44,813 | Nelson, Albin J.      | Reg. No. 28,650 |
| Billion, Richard E.    | Reg. No. 32,836 | Kalis, Janal M.             | Reg. No. 37,650 | Nielsen, Walter W.    | Reg. No. 25,539 |
| Black, David W.        | Reg. No. 42,331 | Kaufmann, John D.           | Reg. No. 24,017 | Oh, Allen J.          | Reg. No. 42,047 |
| Brennan, Leoniede M.   | Reg. No. 35,832 | Klima-Silberg, Catherine I. | Reg. No. 40,052 | Padys, Danny J.       | Reg. No. 35,635 |
| Brennan, Thomas F.     | Reg. No. 35,075 | Kluth, Daniel J.            | Reg. No. 32,146 | Parker, J. Kevin      | Reg. No. 33,024 |
| Brooks, Edward J., III | Reg. No. 40,925 | Lacy, Rodney L.             | Reg. No. 41,136 | Perdok, Monique M.    | Reg. No. 42,989 |
| Chu, Dinh C.P.         | Reg. No. 41,676 | Lemaire, Charles A.         | Reg. No. 36,198 | Prout, William F.     | Reg. No. 33,995 |
| Clark, Barbara J.      | Reg. No. 38,107 | LeMoine, Dana B.            | Reg. No. 40,062 | Schumm, Sherry W.     | Reg. No. 39,422 |
| Dahl, John M.          | Reg. No. 44,639 | Litman, Mark A.             | Reg. No. 26,390 | Schwegman, Micheal L. | Reg. No. 25,816 |
| Drake, Eduardo E.      | Reg. No. 40,594 | Lundberg, Steven W.         | Reg. No. 30,568 | Smith, Michael G.     | Reg. No. 45,368 |
| Eliseeva, Maria M.     | Reg. No. 43,328 | Mack, Lisa K.               | Reg. No. 42,825 | Speier, Gary J.       | Reg. No. 45,458 |
| Embreton, Janet E.     | Reg. No. 39,665 | Maeyaert, Paul L.           | Reg. No. 40,076 | Steffey, Charles E.   | Reg. No. 25,179 |
| Fordenbacher, Paul J.  | Reg. No. 42,546 | Maki, Peter C.              | Reg. No. 42,832 | Terry, Kathleen R.    | Reg. No. 31,884 |
| Forrest, Bradley A.    | Reg. No. 30,837 | Malen, Peter L.             | Reg. No. 44,894 | Tong, Viet V.         | Reg. No. 45,416 |
| Gamon, Owen J.         | Reg. No. 36,143 | Mates, Robert E.            | Reg. No. 35,271 | Viksnins, Ann S.      | Reg. No. 37,748 |
| Harris, Robert J.      | Reg. No. 37,346 | McCrackin, Ann M.           | Reg. No. 42,858 | Woessner, Warren D.   | Reg. No. 30,440 |

I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attorney/firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary.

Please direct all correspondence in this case to **Schwegman, Lundberg, Woessner & Kluth, P.A.** at the address indicated below:

**P.O. Box 2938, Minneapolis, MN 55402**  
**Telephone No. (612)373-6900**

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 1 : **Hong Wang**

Citizenship: **United States of America**  
Post Office Address: **39877 Sundale Drive  
#105  
Fremont, CA 94538**

Residence: **Fremont, CA**

Signature: 

Date: **5/18/00**

**Hong Wang**

Full Name of joint inventor number 2 : **Ralph Kling**

Citizenship: **Germany**  
Post Office Address: **1422 Bedford Avenue  
Sunnyvale, CA 94087**

Residence: **Sunnyvale, CA**

Signature: 

Date: **5/13/00**

**Ralph Kling**

X Additional inventors are being named on separately numbered sheets, attached hereto.

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 3 : **Yong-Fong Lee**

Citizenship: **United States of America**  
Post Office Address: **7265 Sleepy Creek Dr.  
San Jose, CA 95120**

Residence: **San Jose, CA**

Signature:   
Yong-Fong Lee Date: 5-18-2000

Full Name of joint inventor number 4 : **David A. Berson**

Citizenship: **United States of America**  
Post Office Address: **2327 Arabian Drive  
Marietta, GA 30062**

Residence: **Marietta, GA**

Signature:   
David A. Berson Date: \_\_\_\_\_

Full Name of joint inventor number 5 : **Michael A. Kozuch**

Citizenship: **United States of America**  
Post Office Address: **13535 SW Chariot Court  
Beaverton, OR 97008**

Residence: **Beaverton, OR**

Signature:   
Michael A. Kozuch Date: \_\_\_\_\_

Full Name of joint inventor number 6 : **Konrad Lai**

Citizenship: **United States of America**  
Post Office Address: **520 SE Columbia River Drive  
#226  
Vancouver, WA 98661**

Residence: **Vancouver, WA**

Signature:   
Konrad Lai Date: \_\_\_\_\_

§ 1.56 Duty to disclose information material to patentability.

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§ 1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to carefully examine:

- (1) prior art cited in search reports of a foreign patent office in a counterpart application, and
- (2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office.

(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being made of record in the application, and

- (1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or
- (2) It refutes, or is inconsistent with, a position the applicant takes in:
  - (i) Opposing an argument of unpatentability relied on by the Office, or
  - (ii) Asserting an argument of patentability.

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of patentability.

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are:

- (1) Each inventor named in the application;
- (2) Each attorney or agent who prepares or prosecutes the application; and
- (3) Every other person who is substantively involved in the preparation or prosecution of the application and who is associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application.

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, agent, or inventor.

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.

# United States Patent Application

## COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as stated below next to my name; that

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled: **CONJUGATE FLOW PROCESSOR**.

The specification of which is attached hereto.

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known to be material to patentability which became available between a filing date of a prior application and the national or PCT international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. § 1.63(e).

I hereby claim foreign priority benefits under 35 U.S.C. §119(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one country other than the United States of America, listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is claimed:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 119(e) of any United States provisional application(s) listed below:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. § 112, I acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became available between the filing date of the prior application and the national or PCT international filing date of this application:

**No such claim for priority is being made at this time.**

I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith:

|                        |                 |                             |                 |                       |                 |
|------------------------|-----------------|-----------------------------|-----------------|-----------------------|-----------------|
| Anglin, J. Michael     | Reg. No. 24,916 | Huebsch, Joseph C           | Reg. No. 42,673 | Nama, Kash            | Reg. No. 44,255 |
| Bianchi, Timothy E.    | Reg. No. 39,610 | Jurkovich, Patti J.         | Reg. No. 44,813 | Nelson, Albin J       | Reg. No. 28,650 |
| Billion, Richard E.    | Reg. No. 32,836 | Kalis, Janal M.             | Reg. No. 37,650 | Nielsen, Walter W.    | Reg. No. 25,539 |
| Black, David W.        | Reg. No. 42,331 | Kaufmann, John D.           | Reg. No. 24,017 | Oh, Allen J.          | Reg. No. 42,047 |
| Brennan, Leonieide M.  | Reg. No. 35,832 | Klima-Silberg, Catherine I. | Reg. No. 40,052 | Padys, Danny J.       | Reg. No. 35,635 |
| Brennan, Thomas F.     | Reg. No. 35,075 | Kluth, Daniel J.            | Reg. No. 32,146 | Parker, J. Kevin      | Reg. No. 33,024 |
| Brooks, Edward J., III | Reg. No. 40,925 | Lacy, Rodney L.             | Reg. No. 41,136 | Perdok, Monique M     | Reg. No. 42,989 |
| Chu, Dinh C.P.         | Reg. No. 41,676 | Lemaire, Charles A          | Reg. No. 36,198 | Prout, William F.     | Reg. No. 33,995 |
| Clark, Barbara J.      | Reg. No. 38,107 | LeMoine, Dana B             | Reg. No. 40,062 | Schumm, Sherry W.     | Reg. No. 39,422 |
| Dahl, John M.          | Reg. No. 44,639 | Litman, Mark A.             | Reg. No. 26,390 | Schwegman, Micheal L. | Reg. No. 25,816 |
| Drake, Eduardo E.      | Reg. No. 40,594 | Lundberg, Steven W.         | Reg. No. 30,568 | Smith, Michael G.     | Reg. No. 45,368 |
| Eliseeva, Maria M.     | Reg. No. 43,328 | Mack, Lisa K.               | Reg. No. 42,825 | Speier, Gary J        | Reg. No. 45,458 |
| Embretson, Janet E     | Reg. No. 39,665 | Maeyaert, Paul L            | Reg. No. 40,076 | Steffey, Charles E.   | Reg. No. 25,179 |
| Fordenbacher, Paul J.  | Reg. No. 42,546 | Maki, Peter C.              | Reg. No. 42,832 | Terry, Kathleen R.    | Reg. No. 31,884 |
| Forrest, Bradley A.    | Reg. No. 30,837 | Malen, Peter L.             | Reg. No. 44,894 | Tong, Viet V.         | Reg. No. 45,416 |
| Gamon, Owen J.         | Reg. No. 36,143 | Mates, Robert E.            | Reg. No. 35,271 | Viksnins, Ann S.      | Reg. No. 37,748 |
| Harris, Robert J.      | Reg. No. 37,346 | McCrackin, Ann M.           | Reg. No. 42,858 | Woessner, Warren D.   | Reg. No. 30,440 |

I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attorney/firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary.

Please direct all correspondence in this case to **Schwegman, Lundberg, Woessner & Kluth, P.A.** at the address indicated below:

**P.O. Box 2938, Minneapolis, MN 55402**

**Telephone No. (612)373-6900**

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 1 : **Hong Wang**

Citizenship: **United States of America**  
Post Office Address: **39877 Sundale Drive  
#105  
Fremont, CA 94538**

Residence: **Fremont, CA**

Signature: \_\_\_\_\_

Date: \_\_\_\_\_

Hong Wang

Full Name of joint inventor number 2 : **Ralph Kling**

Citizenship: **Germany**  
Post Office Address: **1422 Bedford Avenue  
Sunnyvale, CA 94087**

Residence: **Sunnyvale, CA**

Signature: \_\_\_\_\_

Date: \_\_\_\_\_

Ralph Kling

X Additional inventors are being named on separately numbered sheets, attached hereto.

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 3 : **Yong-Fong Lee**

Citizenship: **United States of America**  
Post Office Address: **7265 Sleepy Creek Dr.  
San Jose, CA 95120**

Residence: **San Jose, CA**

Signature: \_\_\_\_\_

  
**Yong-Fong Lee**

Date: \_\_\_\_\_

Full Name of joint inventor number 4 : **David A. Berson**

Citizenship: **United States of America**  
Post Office Address: **2327 Arabian Drive  
Marietta, GA 30062**

Residence: **Marietta, GA**

Signature:   
**David A. Berson**

Date:   
**5/22/00**

Full Name of joint inventor number 5 : **Michael A. Kozuch**

Citizenship: **United States of America**  
Post Office Address: **13535 SW Chariot Court  
Beaverton, OR 97008**

Residence: **Beaverton, OR**

Signature: \_\_\_\_\_

  
**Michael A. Kozuch**

Date: \_\_\_\_\_

Full Name of joint inventor number 6 : **Konrad Lai**

Citizenship: **United States of America**  
Post Office Address: **520 SE Columbia River Drive  
#226  
Vancouver, WA 98661**

Residence: **Vancouver, WA**

Signature: \_\_\_\_\_

  
**Konrad Lai**

Date: \_\_\_\_\_

§ 1.56 Duty to disclose information material to patentability.

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§ 1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to carefully examine:

- (1) prior art cited in search reports of a foreign patent office in a counterpart application, and
- (2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office.

(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being made of record in the application, and

- (1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or
- (2) It refutes, or is inconsistent with, a position the applicant takes in:
  - (i) Opposing an argument of unpatentability relied on by the Office, or
  - (ii) Asserting an argument of patentability.

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of patentability.

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are:

- (1) Each inventor named in the application;
- (2) Each attorney or agent who prepares or prosecutes the application; and
- (3) Every other person who is substantively involved in the preparation or prosecution of the application and who is associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application.

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, agent, or inventor.

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.

## United States Patent Application

### COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as stated below next to my name; that

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled: **CONJUGATE FLOW PROCESSOR**.

The specification of which is attached hereto.

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known to be material to patentability which became available between a filing date of a prior application and the national or PCT international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. § 1.63(e).

I hereby claim foreign priority benefits under 35 U.S.C. §119(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one country other than the United States of America, listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is claimed:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 119(e) of any United States provisional application(s) listed below:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. § 112, I acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became available between the filing date of the prior application and the national or PCT international filing date of this application:

**No such claim for priority is being made at this time.**

I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith:

|                        |                 |                             |                 |                       |                 |
|------------------------|-----------------|-----------------------------|-----------------|-----------------------|-----------------|
| Anglin, J. Michael     | Reg. No. 24,916 | Huebsch, Joseph C.          | Reg. No. 42,673 | Nama, Kash            | Reg. No. 44,255 |
| Bianchi, Timothy E.    | Reg. No. 39,610 | Jurkovich, Patti J.         | Reg. No. 44,813 | Nelson, Albin J.      | Reg. No. 28,650 |
| Billion, Richard E.    | Reg. No. 32,836 | Kalis, Janal M.             | Reg. No. 37,650 | Nielsen, Walter W.    | Reg. No. 25,539 |
| Black, David W.        | Reg. No. 42,331 | Kaufmann, John D.           | Reg. No. 24,017 | Oh, Allen J.          | Reg. No. 42,047 |
| Brennan, Leoniede M.   | Reg. No. 35,832 | Klima-Silberg, Catherine I. | Reg. No. 40,052 | Padys, Danny J.       | Reg. No. 35,635 |
| Brennan, Thomas F.     | Reg. No. 35,075 | Kluth, Daniel J.            | Reg. No. 32,146 | Parker, J. Kevin      | Reg. No. 33,024 |
| Brooks, Edward J., III | Reg. No. 40,925 | Lacy, Rodney L.             | Reg. No. 41,136 | Perdok, Monique M.    | Reg. No. 42,989 |
| Chu, Dinh C.P.         | Reg. No. 41,676 | Lemaire, Charles A.         | Reg. No. 36,198 | Prout, William F.     | Reg. No. 33,995 |
| Clark, Barbara J.      | Reg. No. 38,107 | LeMoine, Dana B             | Reg. No. 40,062 | Schumm, Sherry W.     | Reg. No. 39,422 |
| Dahl, John M.          | Reg. No. 44,639 | Litman, Mark A.             | Reg. No. 26,390 | Schwegman, Micheal L. | Reg. No. 25,816 |
| Drake, Eduardo E.      | Reg. No. 40,594 | Lundberg, Steven W.         | Reg. No. 30,568 | Smith, Michael G.     | Reg. No. 45,368 |
| Eliseeva, Maria M.     | Reg. No. 43,328 | Mack, Lisa K.               | Reg. No. 42,825 | Speier, Gary J.       | Reg. No. 45,458 |
| Embreton, Janet E.     | Reg. No. 39,665 | Maeyaert, Paul L.           | Reg. No. 40,076 | Steffey, Charles E.   | Reg. No. 25,179 |
| Fordenbacher, Paul J.  | Reg. No. 42,546 | Maki, Peter C.              | Reg. No. 42,832 | Terry, Kathleen R.    | Reg. No. 31,884 |
| Forrest, Bradley A.    | Reg. No. 30,837 | Malen, Peter L              | Reg. No. 44,894 | Tong, Viet V.         | Reg. No. 45,416 |
| Gamon, Owen J.         | Reg. No. 36,143 | Mates, Robert E.            | Reg. No. 35,271 | Viksnins, Ann S.      | Reg. No. 37,748 |
| Harris, Robert J.      | Reg. No. 37,346 | McCrackin, Ann M.           | Reg. No. 42,858 | Woessner, Warren D.   | Reg. No. 30,440 |

I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attorney/firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary.

Please direct all correspondence in this case to **Schwegman, Lundberg, Woessner & Kluth, P.A.** at the address indicated below:

**P.O. Box 2938, Minneapolis, MN 55402**

**Telephone No. (612)373-6900**

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 1 : **Hong Wang**

Citizenship: **United States of America**  
Post Office Address: 39877 Sundale Drive  
 #105  
 Fremont, CA 94538

Residence: **Fremont, CA**

Signature: \_\_\_\_\_

Hong Wang

Date: \_\_\_\_\_

Full Name of joint inventor number 2 : **Ralph Kling**

Citizenship: **Germany**  
Post Office Address: 1422 Bedford Avenue  
Sunnyvale, CA 94087

Residence: **Sunnyvale, CA**

Signature: \_\_\_\_\_

Ralph Kling

Date: \_\_\_\_\_

X Additional inventors are being named on separately numbered sheets, attached hereto.

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 3 : **Yong-Fong Lee**

Citizenship: **United States of America**  
Post Office Address: 7265 Sleepy Creek Dr.  
San Jose, CA 95120

Residence: **San Jose, CA**

Signature: \_\_\_\_\_  
**Yong-Fong Lee**

Date: \_\_\_\_\_

Full Name of joint inventor number 4 : **David A. Berson**

Citizenship: **United States of America**  
Post Office Address: 2327 Arabian Drive  
Marietta, GA 30062

Residence: **Marietta, GA**

Signature: \_\_\_\_\_  
**David A. Berson**

Date: \_\_\_\_\_

Full Name of joint inventor number 5 : **Michael A. Kozuch**

Citizenship: **United States of America**  
Post Office Address: 13535 SW Chariot Court  
Beaverton, OR 97008

Residence: **Beaverton, OR**

Signature: \_\_\_\_\_  
**Michael A. Kozuch**

Date: \_\_\_\_\_

**18 MAY 2000**

Full Name of joint inventor number 6 : **Konrad Lai**

Citizenship: **United States of America**  
Post Office Address: 520 SE Columbia River Drive  
#226  
Vancouver, WA 98661

Residence: **Vancouver, WA**

Signature: \_\_\_\_\_  
**Konrad Lai**

Date: \_\_\_\_\_

§ 1.56 Duty to disclose information material to patentability.

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§ 1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to carefully examine:

- (1) prior art cited in search reports of a foreign patent office in a counterpart application, and
- (2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office.

(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being made of record in the application, and

- (1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or
- (2) It refutes, or is inconsistent with, a position the applicant takes in:
  - (i) Opposing an argument of unpatentability relied on by the Office, or
  - (ii) Asserting an argument of patentability.

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of patentability.

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are:

- (1) Each inventor named in the application;
- (2) Each attorney or agent who prepares or prosecutes the application; and
- (3) Every other person who is substantively involved in the preparation or prosecution of the application and who is associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application.

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, agent, or inventor.

Attorney Docket No. 884-225US1

SCHWEGMAN, LUNDBERG, WOESSNER &amp; KLUTH, P.A.

## United States Patent Application

### COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor, I hereby declare that: my residence, post office address and citizenship are as stated below next to my name; that

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled: **CONJUGATE FLOW PROCESSOR**.

The specification of which is attached hereto.

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known to be material to patentability which became available between a filing date of a prior application and the national or PCT international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. § 1.63(e).

I hereby claim foreign priority benefits under 35 U.S.C. §119(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one country other than the United States of America, listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is claimed:

No such claim for priority is being made at this time.

I hereby claim the benefit under 35 U.S.C. § 119(e) of any United States provisional application(s) listed below:

No such claim for priority is being made at this time.

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. § 112, I acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became available between the filing date of the prior application and the national or PCT international filing date of this application:

No such claim for priority is being made at this time.

Attorney Docket No.: 884.225US1  
 CONJUGATE FLOW PROCESSOR  
 Filing Date: Even Date Herewith

Page 2 of 4

I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith:

| Anglin, J. Michael     | Reg. No. 34,816 | Muehlebach, Joseph C.       | Reg. No. 42,673 | Name, Kash            | Reg. No. 44,255 |
|------------------------|-----------------|-----------------------------|-----------------|-----------------------|-----------------|
| Bianchi, Timothy E.    | Reg. No. 39,610 | Jurkovich, Patti J.         | Reg. No. 44,813 | Nelson, Albin J.      | Reg. No. 28,650 |
| Billion, Richard E.    | Reg. No. 32,836 | Kalis, Jana M.              | Reg. No. 37,650 | Nielsen, Walter W.    | Reg. No. 25,539 |
| Black, David W.        | Reg. No. 42,331 | Kraufmann, John D.          | Reg. No. 24,017 | Oh, Allen J.          | Reg. No. 42,047 |
| Brennan, Leoniede M.   | Reg. No. 35,832 | Klima-Silberg, Catherine I. | Reg. No. 40,052 | Padys, Danny J.       | Reg. No. 35,635 |
| Brennan, Thomas F.     | Reg. No. 35,075 | Kluth, Daniel J.            | Reg. No. 32,146 | Parker, J. Kevin      | Reg. No. 33,024 |
| Brooks, Edward J., III | Reg. No. 40,925 | Lacy, Rodney L.             | Reg. No. 41,136 | Perdok, Monique M.    | Reg. No. 42,989 |
| Chu, Dinh C.P.         | Reg. No. 41,676 | Lemaire, Charles A.         | Reg. No. 36,198 | Prout, William F.     | Reg. No. 33,995 |
| Clark, Barbara J.      | Reg. No. 38,107 | LeMoine, Dana S.            | Reg. No. 40,062 | Schumm, Sherry W.     | Reg. No. 39,422 |
| Dahl, John M.          | Reg. No. 44,639 | Litman, Mark A.             | Reg. No. 26,390 | Schwegman, Michael L. | Reg. No. 25,816 |
| Drake, Eduardo E.      | Reg. No. 40,594 | Lundberg, Steven W.         | Reg. No. 30,568 | Smith, Michael G.     | Reg. No. 45,368 |
| Eliscerova, Maria M.   | Reg. No. 43,328 | Mack, Lisa K.               | Reg. No. 42,825 | Speier, Gary J.       | Reg. No. 45,458 |
| Embreton, Janet E.     | Reg. No. 39,665 | Macyaert, Paul L.           | Reg. No. 40,076 | Steffey, Charles E.   | Reg. No. 25,179 |
| Fordenthaler, Paul J.  | Reg. No. 42,546 | Malki, Peter C.             | Reg. No. 42,832 | Terry, Kathleen R.    | Reg. No. 31,884 |
| Forrest, Bradley A.    | Reg. No. 30,837 | Malen, Peter L.             | Reg. No. 44,894 | Tong, Viet V.         | Reg. No. 45,416 |
| Gamon, Owen J.         | Reg. No. 36,143 | Mates, Robert E.            | Reg. No. 35,271 | Viksnins, Ann S.      | Reg. No. 37,748 |
| Harris, Robert J.      | Reg. No. 37,346 | McCrackin, Ann M.           | Reg. No. 42,858 | Woessner, Warren D.   | Reg. No. 30,440 |

I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attorney/ firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary.

Please direct all correspondence in this case to Schwegman, Lundberg, Woessner & Kluth, P.A. at the address indicated below:

P.O. Box 2938, Minneapolis, MN 55402

Telephone No. (612)373-6900

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 1: Hong Wang  
 Citizenship: United States of America  
 Post Office Address: 39877 Sundale Drive  
#105  
Fremont, CA 94538

Residence: Fremont, CA

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
Hong Wang

Full Name of joint inventor number 2: Ralph Kling  
 Citizenship: Germany  
 Post Office Address: 1422 Bedford Avenue  
Sunnyvale, CA 94087

Residence: Sunnyvale, CA

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
Ralph Kling

X Additional inventors are being named on separately numbered sheets attached hereto.

Application Number: 09/422501US  
CONJUGATE FLOW PROCESSOR  
Filing Date: Even Date Herewith

Page 3 of 4

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 3: Yong-Fong Lee

Citizenship: United States of America  
Post Office Address: 7265 Sleepy Creek Dr.  
San Jose, CA 95120

Residence: San Jose, CA

Signature: Yong-Fong Lee

Date: \_\_\_\_\_

Full Name of joint inventor number 4: David A. Berson

Citizenship: United States of America  
Post Office Address: 2327 Arabian Drive  
Marietta, GA 30062

Residence: Marietta, GA

Signature: David A. Berson

Date: \_\_\_\_\_

Full Name of joint inventor number 5: Michael A. Kozuch

Citizenship: United States of America  
Post Office Address: 13535 SW Chariot Court  
Beaverton, OR 97008

Residence: Beaverton, OR

Signature: Michael A. Kozuch

Date: \_\_\_\_\_

Full Name of joint inventor number 6: Konrad Lai

Citizenship: United States of America  
Post Office Address: 520 SE Columbia River Drive  
#226  
Vancouver, WA 98661

Residence: Vancouver, WA

Signature: Konrad Lai

Date: \_\_\_\_\_

22 May 2000

Attorney Docket No.: 884.225US1  
 CONJUGATE FLOW PROCESSOR  
 Filing Date: Even Date Herewith

Page 4 of 4

**§ 1.56 Duty to disclose information material to patentability.**

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§ 1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to carefully examine:

- (1) prior art cited in search reports of a foreign patent office in a counterpart application, and
- (2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office.

(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being made of record in the application, and

- (1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or
- (2) It refutes, or is inconsistent with, a position the applicant takes in:
  - (i) Opposing an argument of unpatentability relied on by the Office, or
  - (ii) Asserting an argument of patentability.

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of patentability.

- (c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are:
  - (1) Each inventor named in the application;
  - (2) Each attorney or agent who prepares or prosecutes the application; and
  - (3) Every other person who is substantively involved in the preparation or prosecution of the application and who is associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application.
- (d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, agent, or inventor.